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SYSTEM AND METHOD FOR REAL-TIME 
ELECTRONIC ENGINE CONTROL 

CROSS REFERENCE TO RELATED 

APPLICATIONS s 

This application is based on provisional application Ser. 
No. 60/163,253, titled "System and Method for Real-Time 
Electronic Engine Control," filed Nov. 3, 1999. 

FIELD OF THE INVENTION 10 

The present invention is directed to electronic control of 
engines. More specifically, the present invention is directed 
to a system and method for electronically controlling an 
engine including the ability to reprogram control variables 
without interrupting control operation. 

BACKGROUND OF THE INVENTION 

Electronic control of engines for automotive and related 
applications is known. Most control schemes involve cal- 2Q 
culation of controllable variables in real time based upon 
prestored relationships and inputs from sensors that monitor 
engine operation. Most control schemes enable control 
variables to be calculated in both open- loop operation during 
engine warm-up when engine fluid temperatures necessitate 25 
a richer air/fuel ratio, and in closed-loop operation under 
normal operating conditions when feedback from an oxygen 
sensor in the engine exhaust is used to monitor the air/fuel 
ratio. These control schemes typically require time to cal- 
culate the control variables. 3Q 

To reduce calculation time, look-up tables are used to 
obtain control parameters during engine operation. Initially, 
it was proposed to employ look-up tables in open-loop 
control during engine warm-up. A serious problem and 
limitation of such systems lies in the requirement that the 35 
tables be permanently stored in a programmable read-only 
memory or PROM that is initially programmed at the 
factory, and that requires removal and replacement to change 
or reprogram any of the stored control variables. Although 
such requirement for removal and replacement at a factory 40 
service facility or the like has been considered to be accept- 
able for normal passenger car and light truck applications in 
view of EPA requirements that critical engine control param- 
eters not be variable outside of an authorized service 
environment, such schemes are unacceptable for racing and 45 
other off-road applications, and in development and test 
environments. In applications of these types, it is necessary 
that the control variables be readily, individually and selec- 
tively reprograrnnable by a technician or other operator at 
the site. 50 

An engine control system that utilizes look-up tables 
stored in an EEPROM during both wann-up and normal 
operation was developed. An external programming unit 
enabled system memory to be reprogrammed without requir- 
ing removal of the memory package, to accommodate spe- 55 
cific vehicle conditions, such as fuel quality, climate, etc. 
Nevertheless, control variables could not be adjusted during 
actual engine operation. 

Subsequent developments have enabled control variables 
to be adjusted during engine operation. Nevertheless, those 60 
adjustments do not immediately take effect and control does 
not take place when adjustments are being made. Rather, 
when a user is making adjustments to a particular control 
variable, the control relationship using the particular control 
variable is temporarily disabled. This leads to loss of respon- 65 
siveness in the control process and to a potential dangerous 
situation. 
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SUMMARY OF THE INVENTION 

It is an object of the present invention to overcome these 
and other drawbacks with conventional engine control sys- 
tems. 

It is another object of the present invention to provide a 
system and method for electronic control of engine opera- 
tion that enables real-time reprogrammability of engine 
control relationships without disabling control functionality. 

It is another object of the present invention to provide a 
system and method for electronic control of engine opera- 
tion that enables reprogramming of engine control relation- 
ships and the control algorithm. 

Another object of the invention is to provide a method and 
system for electronic engine control in which the engine 
control variables may be readily and selectively varied in 
real time without disabling control functionality, so that the 
operator may readily observe the effects of parameter varia- 
tion and make any desired further adjustments without 
necessitating removal of table memory or other electronic 
circuitry. 

Another object of the present invention is to provide a 
system and method for electronic engine control in which 
control variable tables are displayed to an operator to 
facilitate selective variation of the control relationships. 

According to one embodiment, an engine control system 
for providing electronic control signals to an engine is 
disclosed. The system comprises one or more sensors that 
produce input signals in response to engine operating con- 
ditions and one or more control apparatus, responsive to the 
electronic control signals, that control engine operating 
conditions. An electronic control unit produces the elec- 
tronic control signals in response to the input signals based 
on a set of defined relationships and a-user controller 
enables viewing and modifying of the set of defined rela- 
tionships. The electronic control unit comprises a unique 
memory structure that enables selective rewriting of the set 
of defined relationships in real-time without interrupting 
control operation by the user controller. 

According to another embodiment, a method of control- 
ling an engine is disclosed. The method comprises providing 
one or more input signals in response to engine operating 
conditions and producing electronic control signals in 
response to the input signals based on a set of defined 
relationships. The electronic control signals are used by one 
or more control apparatus that control engine operating 
conditions. The defined relationships may be selectively 
modified in real-time without interrupting the production of 
electronic control signals. 

Other features and advantages of the present invention 
will be apparent to one of ordinary skill in the art upon 
reviewing the detailed description of the present invention. 

BRIEF DESCRIPTION OF THE DRAWINGS 

FIG. 1 is a schematic block diagram of an electronic 
engine control system according to one embodiment of the 
present invention. 

FIG. 2 is a schematic block diagram of an engine control 
unit according to one embodiment of the present invention. 

FIG. 3 is a flow chart of a method for controlling an 
engine according to one embodiment of the present inven- 
tion. 

FIG. 4 is a flow chart of an input capture routine according 
to one embodiment of the present invention. 

FIG. 5 is a flow chart of an output compare routine 
according to one embodiment of the present invention. 
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FIG. 6 is a flow chart of a method for adjusting an engine 242 (indicates air pressure within the engine air intake 

control relationship according to one embodiment of the manifold, which is indicative of engine load), slew fuelinput 

present invention. 243 (enables rapid user control of the fuel supply to deter- 

FIG. 7 shows an exemplary graphical user interface used mine wh , at f^™*^ ° D °P eration at 

to select a control relationship in conjunction with the 5 a given load/RPM point) manifold air temperature sensor 

• j w~*t s-i £ 244, slew spark input 245 (enables rapid user control of the 

method of FIG. 6. i ■ , j , ■ t_ * & * n i u 

spark timing to determine what effect more/less spark has on 

FIG. 8 shows an exemplary graphical user interface used cngine operation at a given load/RPM point), engine coolant 

to display and adjust the fuel map. temperature sensor 246 and battery voltage input 247 

FIG. 9 shows an exemplary graphical user interface used 1Q (reduced voltage input to micro -controller 20 that is indica- 

to display and adjust the spark table. tive of battery voltage — e.g. a 4.8 V input represents 16 V 

FIG. 10 shows an exemplary graphical user interface used at the battery). Each of these sensors may comprise appro- 

to display and adjust the idle air control relationship. P riate conventional sensors. 

FIG. 11 shows an exemplary graphical user interface used The digital inputs include a park/neutral signal 250 

* , j j- . *u •* *j u- (indicates current drive status of vehicle to prevent engine 

to display and adjust the nitrous oxide control relationship. „ \ lQm bein eMed fa } veMcle ^ si al s 25 l 

FIG. 12 shows an exemplary graphical user interface used ( determ ines vehicle speed based on drive shaft rotation), ac 

to display and adjust various closed loop parameters. compressor request signal 252 (indicates ac compressor is 

FIG. 13 shows an exemplary graphical user interface used on and therefore engine load has increased), REF/P1P signal 

to display and adjust various hardware parameters. 253 (signal from OE distributor module indicates spark 

20 reference and provides system trigger for GMs and Fords 

DETAILED DESCRIPTION OF THE respectively), NOS enable signal 254 (indicates the Nitrous 

PREFERRED EMBODIMENTS oxide enrichment has been selected), IPU input 255 

A method and system for controlling an engine is dis- (magnetic input to be used as a spark reference for crank 

closed. According to one embodiment, the present invention 'ngger wheel configurations) knock input 256 (output from 

advantageously permits a user to modify the defined rela- » a ^ sen H sor >' co ! ,n P* 2S ] < ln P u from 

, . 6 . ' v . . . . '. „. . c „ primary used as an alternate system trigger to REF/PIP and 

tionships that are used to control the engine. Significantly, f pu) > wi , ched . t (inpu f indicaljng tnat the 

the method and system of the present mvention enable those k tQ thc engine r has been tumed oo) and mode selec , input 

control relationships to be adjusted on-the-fly without inter- 259 (si , indicating whetner m ic ro-controller 20 should 

eT"ne S contro°unii OPeraUOn " ^ C ° nVCnU ° nal 30 °P<™'e ^mA mode or programmed mode). 

engine con ro uni . j n response to these analog and digital inputs, ECU 13 

FIG. 1 illustrates an engine control system in accordance prodlJces a number of conlro i signals. Specifically, ECU 13 

with one embodiment of the invention. The engine control prodiacC s a stepper motor driver signal 260 (used to control 

system of FIG. 1 comprises an internal combustion engine the idle air stepper motor (IAC) coupled l0 the man ifold air 

10, an engine control unit 13 and a user controller 14. 35 bypass of engine for adjusting idle speed ) ; fu cl injector 

Internal combustion engine 10 comprises a number of driv er signals 261 (pulsed signals of controlled time duration 

control mechanisms 11 that are responsive to control signals uscd t0 coatrol a phira]ity of fud mjectors fof injecting 

developed by engine control unit (ECU) 13, and a number desired quantities of foel t0 the ^ ^fold adja cent to the 

of sensors 12 that develop analog and digital signals for use cylinder inUke ports of the engine) . electronic igriition 

by ECU 13. 4q control signal 262 (used to control spark timing of the 

ECU 13 is shown and will be explained in more detail in engine); bypass/aux control signal 263 (in aux mode may be 

conjunction with FIG. 2. Briefly, ECU 13 receives analog used? eig>j f or controlling a plurality of LEDs on an operator 

and digital input signals from sensors 12 and in response console or panel to indicate any fault or warning conditions 

provides control signals to control mechanisms 11. ECU to the operator; in bypass mode may be used to control the 

develops these control signals based on a set of predefined 45 function of certain ignition modules, e.g., GM ignition 

relationships that are stored therein. According to one modules); fuel pump control signal 264 (used to control a 

embodiment, ECU 13 communicates with user controller 14. fuel pump to feed fuel from a tank or supply (not shown) to 

User controller 14 communicates with and is operative to the injectors of engine); cooling fan control signal 265 (used 

reprogram ECU 13. According to one embodiment, user to control a fan to cool fluid in the radiator based on engine 

controller 14 comprises a personal computer that commu- 50 temperature); CD ignition control signal 266 (used to control 

nicates with ECU through a standard modem. According to firing of an after-market CD and thus timing of the engine) 

one specific embodiment, user controller 14 comprises a and NOS control signal 267 (used to control a solenoid used 

laptop computer including a display screen to view engine to provide NOS injection). 

control relationships (for example, tables of control Microcontroller 20 receives the various analog inputs 

variables) and a keyboard and mouse that is used to modify 55 (240-247) and digital inputs (250-259) and generates the 

those control relationships. control signals (260-267) using control relationships stored 

FIG. 2 depicts ECU 13 in more detail. ECU 13 comprises in nonvolatile memory 21. According to one embodiment, 

micro-controller 20, nonvolatile memory 21, flash memory microcontroller 20 comprises any suitable microprocessor 

22, and serial communications port 23. ECU 23 is respon- based controller. According to one specific embodiment, 

sive to a number of sensors that produce analog inputs and 60 microcontroller 20 comprises a Motorola HC68HC11 

a number of digital inputs. microprocessor. Other microprocessors are possible. 

The analog inputs include inputs from throttle position According to one embodiment, the present invention 

sensor 240 (indicates the degree of rotation of the engine comprises two separate memories. Nonvolatile memory 21 

throttle under control of the operator), exhaust gas oxygen is used to store the control relationships that are used to 

sensor 241 (positioned in the engine exhaust and is used to 65 develop control signals in conjunction with the various 

determine the richness and leanness of the air/fuel mixture analog and digital inputs. Flash memory 22 is used to store 

entering the cylinders), manifold absolute pressure sensor the executable code for microcontroller 20. 
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Nonvolatile memory 21 employs a two tier memory According to one embodiment, the program depicted in FIG. 

structure that comprises a working storage area and a 3 comprises real-time chores that are accomplished at 4, 8, 

non-volatile storage area. The working storage area com- 16, 32, and 64 ms. Other intervals are possible. According to 

prises a read/write memory trlat is used to 7 store the control oat embodiment, the polled real-time chores at each interval 

relationships during engine operation. According to one 5 comprise separate subroutines. According to one 

embodiment, the working storage area comprises memory embodiment, the following chores comprise real-time polled 

that can be written and rewritten in real-time so that control chores Other chores may be added Moreover, the chores 

operation is not interrupted even while the control relation- outlined below may also be moved into any of the other 

ships are being modified. According to one embodiment, T0U *™ S > mam P ro g ram or the r ° utines , of FI U GS - 4 

.working storage area comprises RAM. The non-volatile 10 andS.According to one ^embodiment, readings from i throttle 

Storage area comprises memory that stores the control f^ 1 ™ s f nsor 240 > exhaust g^f oxygen sensor 241, mani- 

relationships when power is lost to microcontroller 20. fold absolute pressure sensor 242 slew fuel sensor 243, 

According to one embodiment^non.volatile storage area mamfold ai , r temperature sensor 244 slew spark sensor 245, 

^comprises EEPROM. In one particular embodiment, both engine coolant temperature sensor 246 and battery voltage 

working storage area and non-volatile storage area comprise is sen f> r 24 ] are ch ' cked > and their valu , es are convert ^ from 

a single non-volatile static RAM chip. Such a chip com- anal °g values 10 dl S llal values in real " time at ste P ^ 

prises both RAM and a backup non-volatile EEPROM for ^ running counter comprises a counter that is used to 

storing information when power is lost. determine whether or not the engine being controlled is 

™ . . i . « a * operating properly. The running counter is monitored and 

Bash memory 22 comprises a memory that is used to . r v, , r / iL . & . , , • 4l _ 

; . i . r f . t ii in a j • on incremented dunng the regular intervals in the main pro- 
store the executable code for microcontroller 20, As dis- 20 . t j j • *u ■ * * *■ / i ■ a 
, , , 4 „ , gram and cleared dunng the input capture routine (explained 
cussed above, in conventional microcontrollers it was not r . ... 4 , , r * £ f v*u • 

. , ' .„ i( , L1 j pi ,» ,« in coniunction with FIG. 4 below). Therefore, it the running 

possible to rewrite the executable code. Rather,, the memory / . . . ' . 

f ... . ,„■•«■ / rnnxm counter rises above a particular value it provides an lndica- 

r holding the executable code, typically some type of ROM, 4 . , iL . 4 f /iL . ...... j . . 

V jt: u j l • \t_ / tion that the input capture routine (that is initiated based on 

had to be swapped with a memory having the new execut- i u & * \ L . u - > a a a- i 

~Ti j • « t 4 : a . ^ i< crankshaft rotation) has not been initiated and accordingly, 

able code burned in. In contrast, flash memory 22 com- 25 A , 7 A , A , ° \ 

. 4 L1 t iM jl ... that the engine has stopped. According to one embodiment, 

pnses a wnteable, non -volatile memory. According to one . . ■ r? a i *u * * 

r ... , a . ~~ . n trnnAw the running counter comprises a software module that is 

embodiment, flash memory 22 comprises ra flash EPROM. ° . . * j 4 i • * * » .. 

rm. 1 .I ^ c L • * ii ~ "tl monitored and incremented at regular intervals. According 

Thus, executable code for the microcontroller can be rewnt- 4 ». • . j ■ * * *i_ • i_ x. a 

ten as necessar embodiment, if the running counter has reached a 

en as necessary. value of 128, it is an indication that the engine is not running 

Serial communications port 23 enables microcontroller 20 properly, and engine control unit 13 is reset, 

to communicate with other devices. According to one According t0 anolher embodiment, the idle air control 

embodiment, user controller 14 communicates with micro- ^ motor {s ^ ^ a& 0Qe of ^ 

controller 20 through serial communications port 23. Thus, chores Tfae ^ motor 260 {& of a piD 

serial communications port 23 is the commumcaUons port { (see 44 of HG 4) ^ maintains c ine idle d 

through which the control relationships and executable code at a ro rammed RPM level. Specifically, engine speed and 

for microcontroller 20 are rewritten. According to one {hc ratc and direction of ch of cn ^ ne d are moni . 

embodiment, serial communications port 23 enables com- tored and adjustments t0 IAC stepper motor position are 

munication of microcontroller 20 with a remote device made to either incrcase or decrease b air flow t0 and 

through a modem. According to one specific embodiment, thus tQ incfease or decfease en ^ ne ^ ^ respectively, 

serial communications port 23 comprises an RS232 com- A ... t . c , c 

munications ort According to another embodiment, the rate of change or 

p throttle position is calculated as one of the real-time chores. 

FIGS. 3, 4, and 5 depict flowcharts showing a method of ^ rate of change in throttle position ^ ^ to determine 

controlling an engine according to one embodiment of the whether or not transient fueling is necessary. In a simulta- 

present invention. According to one embodiment, the 45 neous doub i e . fire engine f uel delivery system, fuel is deliv- 

method of controlling an engine comprises one or more ered 0Qce per cra nkshaft revoluUon. Injector pulses are 

computer programs that control an engine control unit such synchronous with the trigger input from the engine tachom- 

as ECU 13 and specifically microcontroller 20. FIG. 3 is a eter If tne throttle is opened abrupt i y) synchronous fuel 

flowchart of the main program, FIG. 4 is a flowchart for an delivery is typically insufificient, and the engine may hesitate 

input capture routine, and FIG. 5 is a flowchart for an output 5Q or backfire , To overcome this problem, additional fuel pulses 

compare routine. Each of FIGS. 3, 4 and 5 are explained in are delivered between the synchronous pulses. This is 

detail below. termed asynchronous fueling in the art because the addi- 

The method of FIG. 3 begins in step 31 by monitoring tional fuel is not synchronized with the tachometer signal. 

ECU 13 to determine if the ECU is operating properly. The When the engine is cold, transient response is greatly 

method comprises a safety mechanism that will reset the 55 improved by the addition of asynchronous fuel, while at 

ECU (and the engine) if it is not operating properly. Accord- hotter engine temperatures asynchronous fuel tends to over 

ing to one embodiment, the safety mechanism comprises a fuel the engine. According to one embodiment, a defined 

software module that determines whether or not a set of relationship between the rate of change of throttle position 

instructions has been received. If the set of instructions has and engine coolant temperature is used to determine whether 

been received, it is determined that the ECU is operating 60 or not asynchronous fueling is appropriate, 

properly and there is no need to shut the engine down. If the According to another embodiment, the rate of change of 

instructions are not received, it is determined that the engine manifold pressure is a real-time chore and is used to deter- 

is not operating properly and the ECU is reset and the engine mme whether or not transient fueling is required. According 

is shut down. t0 one embodiment, similar to explained above, a defined 

In step 32, the method accomplishes a number of polled 65 relationship between the rate of change of manifold pressure 

real-time chores. The polled real time chores comprise a set and engine coolant temperature is used to determine whether 

of operations that are accomplished at regular intervals. or not synchronous fueling is appropriate. 
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According to another embodiment, the knock signal 256 
is also monitored. As shown in FIG. 2, the knock sensor 
comprises a separate digital input to the ECU. According to 
one embodiment, each time a knock is detected, a pro- 
gramed amount of timing is removed. 

According to another embodiment, a number of control 
parameters are looked up as real-time chores. According to 
one embodiment, these control parameters are based on the 
current operating conditions of the engine. One example of 
a control parameter that is looked up as a part of the 
real-time chores is the park position for the IAC stepper 
motor. 

Returning to FIG. 3, in step 33, x-axis pointers are 
calculated for the control matrices. According to one 
embodiment, defined relationships are used in conjunction 
with sensor readings to control engine performance. For 
example, in conjunction with the system shown in FIGS. 1 
and 2, for every possible reading of manifold absolute 
pressure sensor 244 and vehicle speed sensor 251, micro- 
controller 20 provides a particular control signal to fuel 
injector drivers 261. The same is true for the other sensors 
and control mechanisms shown in FIG. 2. These relation- 
ships between the sensor readings and the control signals 
can be expressed in a number of different ways including in 
a matrix of numbers, and in a graph. In either case, it may 
be desirable to view the relationship in more detail in a 
particular area. Therefore, in step 33, x-axis pointers for the 
relationship may be set. Thus, if one area of the relationship 
is of particular interest, a user may set several pointers in that 
area, effectively giving more resolution to the relationship 
within that area. According to one embodiment, x-axis 
pointers may be set for each control relationship. According 
to another embodiment, x-axis pointers may be set for the 
fuel map (used to control fuel injector drivers 261) and the 
spark map (used to control electronic ignition controller 
262). 

In step 34, the spark advance is calculated. According to 
one embodiment, the spark advance is calculated using a 
defined relationship (as explained above) based on the RPM 
reading from vehicle speed sensor 251 and a load reading. 
The load reading may comprise either a reading from 
manifold absolute pressure sensor 242, or throttle position 
sensor 240. These two factors, determine a spark advance 
from the defined relationship. 

In step 35, cooling fan 265 is controlled. According to one 
embodiment, cooling fan 265 is controlled using a defined 
relationship based on present readings from engine tempera- 
ture sensor 246. According to one embodiment, if the engine 
temperature is greater than a certain threshold, the cooling 
fan is activated. 

In step 36, fuel pump 264 is controlled. According to one 
embodiment, fuel pump 264 remains on, as long as the 
engine is cranking. According to a specific embodiment, the 
running counter (as explained above) is monitored to deter- 
mine whether or not the engine is cranking. If the running 
counter is less than a predetermined number, the engine is 
cranking, and the fuel pump remains activated. According to 
another embodiment, if the engine continues to crank for 
more than some predetermined amount of time, the fuel 
pump is turned off. According to a specific embodiment, if 
the engine continues to crank for more than 10 seconds, the 
fuel pump is turned off. 

In step 37, the injector opening time is corrected based on 
a defined relationship. The opening time for fuel injectors 
may vary based on the battery voltage. Therefore, in step 37, 
the injector opening time is controlled based on the battery 
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voltage. As explained above, the present invention uses a 
number of defined relationships in conjunction with sensor 
readings to control engine performance. In the case of the 
injector opening time, according to one embodiment, the 

S battery voltage is determined from battery voltage sensor 
247, and the particular injector opening time that is appro- 
priate for that battery voltage is determined in step 37 and 
used to control fuel injector drivers 261. According to 
another embodiment, a correction factor for injector opening 

10 time is determined based on the battery voltage and used to 
control fuel injector drivers 261. 

In step 38, an engine control unit communicates with a 
programmer to adjust engine control relationships. Accord- 
ing to one embodiment, the method of FIG. 3 operates in 

15 conjunction with ECU 13 shown in FIGS. 1 and 2. In this 
embodiment, when user controller 14 communicates with 
ECU 13, control parameters are read from and written to 
non- volatile static memory 22. According to one particular 
embodiment, data is moved in and out of memory 22 in 

20 blocks. Thus, if a user desires to adjust the responsiveness of 
the engine to a change in manifold absolute pressure, the 
entire fuel map may be pulled from memory 22 and sent to 
user controller 14 through RS232 communication port 23. A 
user can then view the map at user controller and make 

25 appropriate adjustments. 

In step 39, a determination is made whether the engine is 
running in crank mode or run mode. Depending on whether 
the engine is operating in run or crank mode, a different set 
of operations is accomplished. According to one 

30 embodiment, it is determined that the engine is operating in 
run mode if it has been operating at greater than 350 rpm for 
a predetermined number of cycles. According to a specific 
embodiment, the reading from engine speed sensor 251 is 
used to determine whether the engine is operating in run or 

35 crank mode. If in step 39, it is determined that the engine is 
operating in run mode, operations 310 to 313 are accom- 
plished. If in step 39 it is determined that the engine is 
operating in crank mode, operations 314 to 318 are accom- 
plished. 

In step 310, the 0 2 subroutine is accomplished. In the 0 2 
subroutine, the 0 2 sensor is checked to determine whether or 
not the air fuel mixture needs adjustment. According to one 
embodiment, if air fuel mixture needs to be adjusted, a PI 

45 control loop is used to make the necessary adjustments 
based on a defined relationship between engine speed and 
load. Such adjustments are known in the art. 

In step 311, the nitrous oxide subroutine is called. The 
nitrous oxide subroutine monitors the nitrous enable line 254 

50 shown in FIG. 2, to determine whether or not nitrous oxide 
is to be added to the fuel mixture. If the status of nitrous 
enable line 254 indicates the nitrous oxide is to be added to 
the fuel mixture, and minimum throttle position, time and 
RPM thresholds have been met, it is determined that it is 

55 appropriate to add nitrous. If nitrous is added, appropriate 
adjustments to fuel and timing are made based on the RPM 
reading of vehicle speed sensor 251 and a defined relation- 
ship. 

In step 312, after start subroutine is accomplished. After 
60 start enrichment is intended to help overcome the initial 
start-up frictions and viscosities present in a cold engine, as 
well as to compensate for hot soak fuel vaporization in the 
fuel system of hot engines. The after start subroutine is used 
to add additional fuel to the engine in the time period 
65 following ignition. According to one embodiment, a counter 
is maintained to determine whether or not after start enrich- 
ment is appropriate. The after start counter is incremented in 
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the input capture subroutine shown in FIG. 4 and thus 
provides an indication of the number of crankshaft revolu- 
tions that have occurred. According to one embodiment, if 
the after start enrichment is appropriate, an appropriate 
amount of fuel to be added is determined based on a reading 
of engine speed sensor 251 and a defined relationship. The 
additional fuel to be added is gradually decayed based on a 
defined relationship between the engine coolant temperature 
and the counter. 

In step 313, the fuel injector pulse width subroutine is 
accomplished. Based on a defined relationship between the 
manifold absolute pressure and engine speed, the fuel injec- 
tor pulse width is adjusted. According to one embodiment, 
a look up table is used to store fuel injector pulse width. 
According to one specific embodiment, manifold absolute 
pressure sensor 244 and vehicle speed sensor 251 are read 
and used to determine the appropriate fuel injector pulse 
width under run conditions. 

If it is determined that the engine is operating in crank 
mode in step 39, then, in step 314 an 0 2 delay is determined. 
According to one embodiment, the 0 2 delay is determined 
based on initial coolant temperature and a defined relation- 
ship. As explained previously, the present invention uses a 
number of defined relationships in conjunction with sensor 
readings to control engine performance. According to one 
embodiment, 0 2 delay is determined based on readings from 
engine coolant temperature sensor 246. 

In step 315, the park position for IAC stepper motor is 
determined. According to one embodiment, the park position 
is determined based on initial coolant temperature and a 
defined relationship. As explained previously, the present 
invention uses a number of defined relationships in conjunc- 
tion with sensor readings to control engine performance. In 
the case of the park position, according to one embodiment, 
the park position is determined based on readings from 
engine coolant temperature sensor 246. 

In step 316, it is determined whether or not a flood has 
occurred. If a flood has occurred in step 317, injector pulsing 
is stopped. According to one embodiment, readings from 
throttle position sensor 240 are used to determine whether or 
not a flood has occurred. If throttle position exceeds a certain 
threshold, it is determined a flood has occurred and a clear 
flood mode is initiated. In the clear flood mode, among other 
things, injector pulsing is stopped. 

If it is determined that no flood has occurred, in step 318, 
the crank pulse width for the fuel injector is determined. 
According to one embodiment, the crank pulse width for the 
fuel injectors is determined based on a predefined relation- 
ship with engine coolant temperature. According to one 
embodiment, a look up table is used to store fuel injector 
pulse width under cranking conditions. According to one 
specific embodiment, engine coolant temperature sensor 246 
is read and used to determine the appropriate fuel injector 
pulse width. 

After either the run time or crank time chores have been 
accomplished, the operation of the main program returns to 
step 31. 

FIG. 4 is a flow chart showing a method of capturing input 
for a subroutine of the main program for controlling ECU 13 
shown in FIGS. 1 and 2. The input capture method shown in 
FIG. 4 is initiated based on crankshaft rotation. According to 
one embodiment, the method of FIG. 4 is initiated after the 
crankshaft rotates 90°. Other embodiments are possible. 

The input capture method of FIG. 4 begins with Step 41 
where the spark output configuration is determined. The 
spark output configuration depends on the type of engine 
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that is being controlled. The engine control unit shown in 
FIG. 2 may be used to control a number of different engines. 
According to one embodiment, ECU 13 is used to control an 
engine with an inductive pickup ignition. According to other 

5 embodiments, ECU 13 is used to control other engine types. 
In step 42 the end of dwell (EOD) is calculated. The end 
of dwell is calculated in a manner that is known in the art. 
According to one embodiment, the start of dwell (SOD) is 
calculated in the output interrupt subroutine shown in FIG. 

io 5. 

In step 43 the injectors are fired. According to one 
embodiment, the manner in which the injectors are fired 
depends on, at least, the mode of operation of ECU 13 and 
the number of cylinders. According to one embodiment, the 

15 ECU may operate in conjunction with a port fuel injection 
system or a throttle body fuel injection system and in 
conjunction with engines having any number of cylinders. 
Thus, depending on these two factors, a different set of 
signals are generated by microcontroller 20 and are used to 

20 control fuel injector drivers 261. 

In step 44, idle air stepper motor is controlled. The IAC 
stepper motor is used to control the amount of air in the fuel 
air mixture and thus control the idle speed. According to one 
embodiment, a PID (proportional integral differential) cal- 

25 culation is used to determine the IAC control. According to 
one embodiment, the PID calculation is based on the dif- 
ference between the desired and actual idle speed (as mea- 
sured by vehicle speed sensor 251). 

30 In Step 45 the determination is made as to whether the 
engine is operating in crank mode or run mode. According 
to one embodiment, if the engine is operating at greater than 
350 RPMs for more than a predetermined number of cycles, 
the engine is operating in run mode. Otherwise, it is deter- 

35 mined that the engine is operating in crank mode. 

In Step 46 the running counter is cleared. As explained 
above, the running counter holds a count that is used to 
determine whether the engine and the ECU are operating 
properly. Operation of the input capture subroutine indicates 

40 that the engine and the ECU are operating properly. Thus, in 
step 46 the running counter is cleared. As explained above, 
according to one embodiment, the running counter com- 
prises a software module that is incremented every four 
milliseconds. 

45 In Step 47 the after start counter is incremented. The after 
start counters are used to determine whether or not the 
engine is operating in an after start mode. For a period of 
time after an engine is started a richer fuel air mixture is 
used. The after start counter begins at zero and is incre- 

50 mented each time through the input capture subroutine. 
When the input counter reaches a certain threshold, it is 
determined that the richer fuel air mixture is no longer 
necessary. That is, the engine is no longer operating in an 
after start mode. 

55 FIG. 5 shows a flowchart depicting an output compare 
subroutine. The output compare subroutine is initiated after 
each input capture subroutine. Other embodiments are pos- 
sible. According to one embodiment the input capture sub- 
routine shown in FIG. 4 is used to develop inputs that are 

60 used in the output compare subroutine of FIG. 5. 

The output compare subroutine shown in FIG. 5 begins at 
step 51 by determining the type of ignition system that is 
being used. As explained in conjunction with FIG. 4, step 41, 
the ECU may be used in conjunction with a number of 

65 different engine configurations and ignition systems. Each 
different configuration generally requires a different form of 
output. Thus, in Step 51 the output is configured for the 
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proper ignition system. According to one embodiment the 
ECU is used in conjunction with an inductive pickup igni- 
tion system. 

In Step 52 the start of dwell (SOD) is determined. The 
start of dwell is determined using the inputs developed in the 
input capture subroutine shown in FIG. 4. The start of dwell 
is determined in a manner that is known in the art. 

FIG. 6 is a flowchart showing a method for adjusting 
engine control relationships according to another embodi- 
ment of the present invention. According to one 
embodiment, the engine control relationships are adjusted 
by a user through a personal computer. The method will be 
explained in conjunction with the method and system shown 
in FIGS. 1-5. In that system, as explained above, user 
controller 14 is provided to accomplish modification of the 
control relationships. 

Before the method begins, a number of engine parameters 
are set. The method and system of the present invention is 
useful in conjunction with a number of different engine types 
that have different specifications. According to one 
embodiment, these specifications such as the number of 
cylinders, and whether the engine uses throttle body fuel 
injection or port fuel injection are selected before control 
begins. 

The method begins in step 61 with selection of a control 
parameter for adjustment. According to one embodiment, a 
user may select any of a plurality of control relationships for 
adjustment. These control relationships are generally known 
in the art and are explained briefly below. 

The fuel relationship controls the injector pulse width 
under run conditions based on manifold absolute pressure 
and engine speed. According to one embodiment, this rela- 
tionship is utilized at step 313 of the control method shown 
in FIG. 3. 

Hie spark relationship controls the spark timing based on 
engine speed and engine load. Engine load may be measured 
by manifold absolute pressure or by throttle position. 
According to one embodiment, the spark relationship is 
utilized at step 34. 

At least two relationships are used to control the idle that 
may be chosen in step 62. The idle speed relationship 
controls the speed of the idle through control of I AC stepper 
motor and depends on engine coolant temperature. Accord- 
ing to one embodiment, the idle speed relationship is utilized 
in step 44 of FIG. 4. The idle park position relationship 
controls the position in which the idle is parked and depends 
on engine coolant temperature. According to one 
embodiment, the idle park position relationship is utilized in 
step 315 of FIG. 3. 

The throttle follower relationship allows a user to monitor 
the throttle position and idle bypass air of the engine, and to 
set the minimum limit of the bypass air. The purpose of the 
throttle follower relationship is to back the idle control 
mechanism away from its stop at the fully closed position, 
thereby leaking more air into the intake manifold at off-idle 
speeds to keep it from smothering the engine during rapid 
deceleration. 

A number of acceleration enrichment relationships con- 
trol whether or not additional fuel should be added during 
acceleration condition. According to one embodiment, 
acceleration enrichment is expressed as additional pulse 
width to be added to both synchronous or asynchronous 
pulse widths resulting from the base fuel relationship. Accel- 
eration enrichment relationships depend on: 1) the rate of 
change of the throttle position; 2) coolant temperature; 3) the 
throttle position 4) the rate of change of manifold absolute 
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pressure, 5) a decay rate factor and 6) manifold pressure 
acceleration compensation as a function of coolant tempera- 
ture. 

The after start enrichment relationship controls the 

5 amount of after start fuel to be added to the engine and 
depends on coolant temperature. The after start enrichment 
relationship relates percent enrichment to engine coolant 
temperature. The enrichment percentage is added to the base 
pulse width from the base fuel map. The after start hold off 

30 relationship controls when after start enrichment should 
begin and depends on the number of engine revolutions (as 
measured using, e.g., an after start counter) and engine 
coolant temperature. The amount of enrichment decays at a 
rate specified in an after start enrichment decay relationship. 

15 The after start enrichment decay relationship controls the 
rate at which fuel enrichment is to be diminished and 
depends on engine coolant temperature and the number of 
revolutions that have occurred. According to one 
embodiment, the after start relationships are utilized in step 

20 312 of FIG. 3. 

The warm-up enrichment relationship controls whether or 
not fuel is to be added synchronously while the engine is 
warming up and depends on engine coolant temperature. 
The relationship determines an enrichment factor that 

25 increases the fuel delivered to the engine during warm-up 
based on engine coolant temperature. 

The air temperature enrichment relationship controls 
whether or not fuel is to be added synchronously and 
depends on air temperature into the engine. According to one 
embodiment, the reading of manifold air temperature sensor 
244 is utilized to determine whether or not air temperature 
enrichment is appropriate. 

The cranking pulse width relationship controls the fuel 

35 injector pulse width under cranking conditions. The injector 
pulse width under cranking conditions depends on engine 
coolant temperature. According to one embodiment, this 
relationship is utilized at step 318 of the control method 
shown in FIG. 3. 

4 q According to one embodiment, a graphical user interface 
(GUI) is provided to enable the user to select a particular 
control relationship to modify The GUI may provide any of 
a number of known mechanisms such as text boxes and 
dialog boxes to enable a user to select or enter a particular 

45 control relationship to be adjusted. An exemplary GUI that 
may be used to select a control relationship to modify is 
shown in FIG. 7, FIG. 7 depicts a selection GUI 71. 
Selection GUI 71 comprises a number of pull down menus 
74 that may be used to select various ones of the control 

50 relationships for displaying and adjusting. 

In step 62, the control relationship is accessed. According 
to one embodiment, the method for adjusting the control 
relationship operates in conjunction with the system of 
FIGS. 1 and 2 and user controller 14 communicates with 

55 engine control unit 13, using a modem and serial commu- 
nication port 23, to access the selected control relationship. 
According to this embodiment, control relationships are 
stored in nonvolatile static memory 21. As explained above, 
nonvolatile static memory 21 advantageously enables trans- 

60 fer of data in and out in blocks such that the control 
relationship may be quickly downloaded to user controller 
14 over a modem. 

In step 63, the control relationship is displayed to the user. 
The control relationships vary in complexity. Some, such as 

65 the fuel relationship comprise a look-up table that is 
addressed using the appropriate parameters (manifold abso- 
lute pressure and engine speed in the case of the fuel 
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relationship). According to another embodiment, a two- 
dimensional look-up table may be depicted as a three 
dimensional map. Other control relationships may comprise 
a one dimensional relationship or a single value. According 
to one embodiment, user controller 14 is used to display the 5 
control relationship as a table and/or a graph and/or a 
parameter as appropriate. 

One example of the display of a fuel relationship is shown 
in FIG. 8. FIG. 8 shows the fuel relationship 81 as a matrix 
or map of numbers 82. This fuel map display comprises a 30 
display window having a matrix of numeric parameters that 
form the ECU's base fuel map. The rows correspond to 
manifold absolute pressure and the columns to engine speed 
in RPM. 

FIG. 8 also shows the fuel relationship as a three dim en- 35 
sional graph 83. The three dimensional plot of the base fuel 
map is useful for identifying severe discontinuities or irregu- 
larities in the base fuel map that may otherwise go unnoticed 
in the numeric table. The display of other relationships is 
similar to the display of the fuel relationship. FIGS. 9-13 20 
show GUIs that are used to control other exemplary rela- 
tionships such as the spark table (FIG. 9), IAC (FIG. 10), 
nitrous oxide boost (FIG. 11), closed loop parameters (FIG. 
12), and hardware parameters (FIG. 13). 

In step 64, the selected control relationship is adjusted. 
According to one embodiment, for use in conjunction with 
the display of the relationship as a map, a mouse is used to 
select one of the values in the map in a manner that is known 
in the art. Once the value is selected, the up and down arrow 3Q 
keys on a keyboard may be used to adjust the value. 
Alternatively, the user may simply type a new value over the 
existing value. According to another embodiment, for use in 
conjunction with the display of the relationship as a graph, 
a mouse is used to select and hold a point on the graph. Once 35 
selected the point on the graph may be physically raised or 
lowered using the mouse. Alternatively, once the point on 
the map is selected, the up and down arrow keys on a 
keyboard may be used to adjust the value. Other methods of 
adjusting a value are possible. 4Q 

In steps 65, the adjustments are rewritten to memory in 
the controller and are available for use by the controller in 
real-time. According to one embodiment, when a user uses 
the mouse or keyboard arrows to adjust a control 
relationship, that adjustment is immediately communicated 45 
to the engine control unit and written over the existing 
control relationship. Thus, those adjustments are advanta- 
geously made available for use by the controller in real-time 
without any control disabling in contrast to conventional 
control schemes. According to one embodiment, this is made 50 
possible by the provision of nonvolatile static memory 21 
shown in FIG. 2. The end result is that the effect of the 
adjustments are felt in real time in the vehicle. 

The invention has been described in connection with 
particular embodiments. These embodiments are intended to ss 
be illustrative only. It will be appreciated by those skilled in 
the art that modifications may be made to these preferred 
embodiments without departing from the scope of the inven- 
tion as defined by the appended claims. 

What is claimed is: 60 

1, An engine control system for providing electronic 
control signals to an engine comprising; 
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one or more sensors for producing input signals in 

response to engine operating conditions; 
one or more control apparatus responsive to the electronic 
control signals and operative to control engine operat- 
ing conditions; 
an electronic control unit operative to produce the elec- 
tronic control signals in response to the input signals 
based on a set of defined relationships, and comprising 
a memory, the memory comprising: 
a working storage area operative to store the set of 
defined relationships during operation of the elec- 
tronic control unit, and 
a second storage area operative to store the set of 
defined relationships when the electronic control unit 
loses power; 

a user controller permitting viewing and modifying the set 
of defined relationships; 

wherein the electronic control unit and the user controller 
enable selective rewriting of the set of defined relation- 
ships in real-time without interrupting control opera- 
tion. 

2. The engine control system of claim 1 wherein the 
memory comprises a non-volatile static RAM. 

3. The engine control system of claim 1 wherein the set of 
defined relationships comprises a set of look-up tables. 

4. The engine control system of claim 1 wherein the 
electronic control unit further comprises a microcontroller 
responsive to the input signal. 

5. The engine control system of claim 1 wherein the 
electronic control unit further comprises a flash memory for 
storing executable code for the electronic control unit. 

6. The engine control system of claim 5 wherein the flash 
memory comprises memory that may be rewritten to change 
the executable code for the electronic control unit. 

7. A method of controlling an engine comprising: 
providing one or more input signals in response to engine 

operating conditions; 
producing electronic control signals in response to the 

input signals based on a set of defined relationships; 
selectively modifying the set of defined relationships in 

real-time without interrupting the production of elec- 
tronic control signals; 
storing the set of defined relationships in a working 

storage area of a memory unit during operation; 
storing the set of defined relationships in a second storage 

area of the memory unit upon power loss; 
wherein the electronic control signals are used by one or 

more control apparatus that are operative to control 

engine operating conditions. 

8. The engine control method of claim 7 wherein the set 
of defined relationships comprises a set of look-up tables. 

9. The engine control method of claim 7 wherein modi- 
fying the set of defined relationships comprises modifying 
one or more entries in the set of look-up tables. 

10. The engine control method of claim 7 further com- 
prising storing a log of modifications that are made to the set 
of defined relationships. 

11. The engine control system of claim 7 wherein the 
memory unit comprises a non-volatile static RAM. 
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